<template>
  <t-popup
    v-model:visible="formVisible"
    :on-visible-change="onShareVisibleChange"
    trigger="click"
    placement="bottom-right"
    :overlay-inner-style="{ boxShadow: 'none', padding: '0', borderRadius: '8px' }"
  >
    <share-icon size="1.5em" />
    <template #content>
      <div class="share-container">
        <div class="share-container-main">
          <div class="share-container-main-left">
            <div class="header-name">扫一扫，手机继续看</div>
            <div class="header-info">
              推荐使用 <span class="header-info-browser">夸克浏览器</span> -首页-<camera-icon />-扫码
            </div>
            <div class="header-copyright no-warp">
              <span>{{ data.provider }}</span>
              <span>提供支持,严禁传播资源</span>
            </div>
            <t-divider dashed style="margin: 5px 0" />
          </div>
          <div class="share-container-main-right">
            <qrcode-vue :value="data.url" :size="85" :margin="5" level="H" render-as="svg" class="qrcode" />
          </div>
        </div>
        <div class="bottom-title no-warp">{{ data.name }}</div>
        <div class="bottom-copy">
          <input v-model="data.url" class="input-url" readonly />
          <button class="btn-copy" @click="copyShareUrl">复制地址</button>
        </div>
      </div>
    </template>
  </t-popup>
</template>
<script setup lang="ts">
import { useClipboard } from '@vueuse/core';
import QrcodeVue from 'qrcode.vue';
import { CameraIcon, ShareIcon } from 'tdesign-icons-vue-next';
import { MessagePlugin } from 'tdesign-vue-next';
import { ref, watch } from 'vue';

const props = defineProps({
  visible: {
    type: Boolean,
    default: false,
  },
  data: {
    type: Object,
    default: () => {
      return {
        name: '',
        url: '',
        provider: '',
      };
    },
  },
});

const data = ref(props.data);
const { isSupported, copy } = useClipboard();
const formVisible = ref(false);

const emit = defineEmits(['update:visible']);

watch(
  () => formVisible.value,
  (val) => {
    emit('update:visible', val);
  },
);
watch(
  () => props.visible,
  (val) => {
    formVisible.value = val;
  },
);
watch(
  () => props.data,
  (val) => {
    data.value = val;
  },
);

const copyToClipboard = (content, successMessage, errorMessage) => {
  copy(content);
  if (isSupported) {
    MessagePlugin.info(successMessage);
  } else {
    MessagePlugin.warning(errorMessage);
  }
};

// 点击非浮层元素触发关闭分享
const onShareVisibleChange = (_, context) => {
  // trigger=document 表示点击非浮层元素触发
  if (context.trigger === 'document') formVisible.value = false;
};

// 复制分享地址
const copyShareUrl = () => {
  const successMessage = '复制成功，快分享给好友吧!';
  const errorMessage = '当前环境不支持一键复制，请手动复制链接!';
  copyToClipboard(data.value.url, successMessage, errorMessage);

  formVisible.value = false;
};
</script>

<style lang="less" scoped>
.share-container {
  width: 340px;
  padding: 20px;
  border-radius: 8px;
  position: relative;
  background-color: #2a2a31;
  cursor: default;

  .no-warp {
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
  }

  &-main {
    display: flex;
    justify-content: flex-start;
    height: 85px;

    &-left {
      width: 210px;
      .header-name {
        color: hsla(0, 0%, 100%, 0.87);
        font-size: 15px;
        line-height: 40px;
      }

      .header-info {
        color: hsla(0, 0%, 100%, 0.6);
        font-size: 12px;
        line-height: 20px;

        &-browser {
          color: #61f6ff;
        }
      }

      .header-copyright {
        color: hsla(0, 0%, 100%, 0.6);
        font-size: 12px;
        line-height: 20px;
      }
    }

    &-right {
      margin: 0 0 0 10px;

      .qrcode {
        width: 85px;
        height: 85px;
        border-radius: var(--td-radius-large);
      }
    }
  }

  .bottom-title {
    margin-top: 5px;
    line-height: 20px;
    font-weight: 500;
    color: hsla(0, 0%, 100%, 0.87);
  }
  .bottom-copy {
    margin-top: 5px;
    display: inline-block;
    position: relative;
    width: 100%;
    text-align: right;
    vertical-align: middle;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid hsla(0, 0%, 100%, 0.3);
    height: 43px;
    border-radius: 21px;

    .input-url {
      width: 100%;
      height: 40px;
      background-color: initial;
      border: none;
      outline: none;
      caret-color: #e7e7e7;
      font-size: 14px;
      color: #fff;
      letter-spacing: 0;
      padding: 9px 80px 9px 10px;
      position: absolute;
      left: 0;
    }
    .btn-copy {
      position: relative;
      right: 6px;
      width: 6em;
      height: 30px;
      line-height: 30px;
      border-radius: 15px;
      font-weight: 500;
      background-color: #fff;
      color: #222;
      font-size: 12px;
      top: 5px;
      border: none;
      vertical-align: top;
      cursor: pointer;
    }
  }
}
</style>
